# -*- coding: UTF-8 -*-
"""
字符串的格式化
"""

print('2-格式化输出： format')
s = '名字是:{}，年龄是:{}'.format('tom', 16, 170)  # 顺序填抗
print(s)

print('名字是:{0}，年龄是:{2}'.format('tom', 16, 170))  # 下标填抗
print('名字是:{name}，年龄是:{age}'.format(name='tom', age=16))  # 变量填坑

# 变量填坑可以简写为
name = 'tom'
age = 20
print(f'名字是:{name}，年龄是:{age}')  # 变量填坑

print('{:5}'.format(' b'))  # 指定长度5.输出字符串:左对齐
print('{:5}'.format(3))  # 指定长度.输出数值:右对齐
# 使用>< 避免字符串/数值对齐方法不一致
print('{:>5}'.format('b'))  # 右对齐
print('{:<5}'.format(' 3'))  # 左对齐
print('{:x<5}'.format('3'))  # 左对齐，指定长度不足5补x

# %分号的格式化
string = "hello"

# %s打印时结果是hello
print("string=%s" % string)  # output: string=hello

# %2s意思是字符串长度为2，当原字符串的长度超过2时，按原长度打印，所以%2s的打印结果还是hello
print("string=%2s" % string)  # output: string=hello

# %7s意思是字符串长度为7，当原字符串的长度小于7时，在原字符串左侧补空格，
# 所以%7s的打印结果是  hello
print("string=%7s" % string)  # output: string=  hello

# %-7s意思是字符串长度为7，当原字符串的长度小于7时，在原字符串右侧补空格，
# 所以%-7s的打印结果是  hello
print("string=%-7s!" % string)  # output: string=hello  !

# %.2s意思是截取字符串的前2个字符，所以%.2s的打印结果是he
print("string=%.2s" % string)  # output: string=he

# %.7s意思是截取字符串的前7个字符，当原字符串长度小于7时，即是字符串本身，
# 所以%.7s的打印结果是hello
print("string=%.7s" % string)  # output: string=hello

# %a.bs这种格式是上面两种格式的综合，首先根据小数点后面的数b截取字符串，
# 当截取的字符串长度小于a时，还需要在其左侧补空格
print("string=%7.2s" % string)  # output: string=     he
print("string=%2.7s" % string)  # output: string=hello
print("string=%10.7s" % string)  # output: string=     hello

# 还可以用%*.*s来表示精度，两个*的值分别在后面小括号的前两位数值指定
print("string=%*.*s" % (7, 2, string))  # output: string=     he

num = 14

# %d打印时结果是14
print("num=%d" % num)  # output: num=14

# %1d意思是打印结果为1位整数，当整数的位数超过1位时，按整数原值打印，所以%1d的打印结果还是14
print("num=%1d" % num)  # output: num=14

# %3d意思是打印结果为3位整数，当整数的位数不够3位时，在整数左侧补空格，所以%3d的打印结果是 14
print("num=%3d" % num)  # output: num= 14

# %-3d意思是打印结果为3位整数，当整数的位数不够3位时，在整数右侧补空格，所以%3d的打印结果是14 !
print("num=%-3d!" % num)  # output: num=14 !

# %05d意思是打印结果为5位整数，当整数的位数不够5位时，在整数左侧补0，所以%05d的打印结果是00014
print("num=%05d" % num)  # output: num=00014

# %.3d小数点后面的3意思是打印结果为3位整数，
# 当整数的位数不够3位时，在整数左侧补0，所以%.3d的打印结果是014
print("num=%.3d" % num)  # output: num=014

# %.0003d小数点后面的0003和3一样，都表示3，意思是打印结果为3位整数，
# 当整数的位数不够3位时，在整数左侧补0，所以%.3d的打印结果还是014
print("num=%.0003d" % num)  # output: num=014

# %5.3d是两种补齐方式的综合，当整数的位数不够3时，先在左侧补0，还是不够5位时，再在左侧补空格，
# 规则就是补0优先，最终的长度选数值较大的那个，所以%5.3d的打印结果还是  014
print("num=%5.3d" % num)  # output: num=  014

# %05.3d是两种补齐方式的综合，当整数的位数不够3时，先在左侧补0，还是不够5位时，
# 由于是05，再在左侧补0，最终的长度选数值较大的那个，所以%05.3d的打印结果还是00014
print("num=%05.3d" % num)  # output: num=00014

# 还可以用%*.*d来表示精度，两个*的值分别在后面小括号的前两位数值指定
# 如下，不过这种方式4就失去补0的功能，只能补空格，只有小数点后面的3才能补0
print("num=%*.*d" % (4, 3, num))  # output: num= 014

import math

# %a.bf，a表示浮点数的打印长度，b表示浮点数小数点后面的精度

# 只是%f时表示原值，默认是小数点后5位数
print("PI=%f" % math.pi)  # output: PI=3.141593

# 只是%9f时，表示打印长度9位数，小数点也占一位，不够左侧补空格
print("PI=%9f" % math.pi)  # output: PI=_3.141593

# 只有.没有后面的数字时，表示去掉小数输出整数，03表示不够3位数左侧补0
print("PI=%03.f" % math.pi)  # output: PI=003

# %6.3f表示小数点后面精确到3位，总长度6位数，包括小数点，不够左侧补空格
print("PI=%6.3f" % math.pi)  # output: PI=_3.142

# %-6.3f表示小数点后面精确到3位，总长度6位数，包括小数点，不够右侧补空格
print("PI=%-6.3f" % math.pi)  # output: PI=3.142_

# 还可以用%*.*f来表示精度，两个*的值分别在后面小括号的前两位数值指定
# 如下，不过这种方式6就失去补0的功能，只能补空格
print("PI=%*.*f" % (6, 3, math.pi))  # output: PI=_3.142
